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SYSTEM AND PROCESS FOR FLEXIBLE QUEUING OF 
DATA PACKETS IN NETWORK SWITCHING 

CROSS REFERENCE 

5 

This application is being filed with applications for 
United States Patents for * System and Process for Application- 
Level Flow Connection of Data Processing Networks" by Barry 
Spinney et al. "High-Speed Data Bus for Network Switching" by 

10 Nigel Poole, * System and Process for High-Speed Pattern 

Matching for Application -Level Switching of Data Packets" by 
Barry Spinney et al., filed April 10, 1998, which have 
substantially similar disclosures and are assigned to a common 
entity, Top Layer Networks, Inc., formerly called BlazeNet, 

1 5 Inc . 

BACKGROUND OF THE INVENTION 

The field of the invention is that of the networking of 

20 data processing systems or computers and, more particularly, 
that of the switchable connection of Local Area Networks 
("LANs") such as those supported by the Ethernet protocol and 
Wide Area Networks ("WANs") such as those supported by the 
Asynchronous Transfer Mode ("ATM") protocol. 

25 One of the major problems in the field of connecting 

networks is that the variety of different network protocols 
used to communicate between different data processing systems 
on particular networks makes communication between such 
networks difficult. Another major problem is that most 

30 network protocols require considerable configuration of 
parameters when adding computer systems or nodes, typically 
accomplished by manual input of device addresses by network 
professionals who nonetheless make mistakes. This problem may 
be exacerbated when connecting across network boundaries. 

35 Current connection of networks, including the mechanisms 

used to connect the Internet, is accomplished using devices 
known as "bridges" and "routers." Roughly speaking, bridges 
connect different networks at the "data link" layer or Layer 2 
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of the OSI Network model, see Schwartz, Mischa, 
Telecommunication Networks at 75-99 (Addison-Wesley 1987), and 
routers connect different networks at the "network" layer or 
Layer 3 of the OSI model. A packet of data is preceded by 
headers corresponding to layers of communication, with the 
first in time header corresponding to the lowest Layer 1, the 
physical link, and proceeding up to Layer 7, the application 
layer (other models have fewer layers and the "application 
layer" may refer and here refers to functions at Layers 5-7 of 
the OSI model). When packets of information are received at a 
bridge, the bridge processor forwards the packet on a data 
link according to the information in the data link header 
(following the physical link header). When packets of 
information are received at a router, the packet is routed 
according to the information in the network header. These 
headers, however, do not contain information about the quality 
of service required by the application to which the data 
packet pertains; thus, each packet is forwarded according to 
the data link or network protocol which may or may not include 
a priority flag, typically for network management operations. 

The types of applications requiring data transmission on 
current networks call for a wide range of service. Thus, in 
communications with a file server, requests uploaded from a 
client for downloading of data require relatively little 
bandwidth, while downloading of massive amounts of data 
requires great bandwidth to be accomplished in a reasonable 
time. Streaming of audio-visual ("multimedia") information 
requires guaranteed bandwidth at regular intervals to avoid 
perceivable interruptions or "jitter". E-mail, file server 
requests, HTTP, word processing each have their own 
application protocols with associated header information that 
can be associated with their communication needs, including 
bandwidth . 

Network switching schemes that consider information above 
the network layer, so-called "Layer 4 switches," are just 
coming on the market and appear typically to involve software 
implementations that are slow and only consider a portion of 
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the Layer 4 or transport layer header (the -TCP" part of 
TCP/IP or transport control protocol /internetwork protocol) . 

SUMMARY OF THE INVENTION 

The present invention connects networks at the 
application layer, and uses more information above Layer 3 of 
the OSI model, than other network switches in the present 
state of the art. The invention performs "flow switching " or 
connection, wherein, based on the information in a received 
data packet at Layer 4 and above, the invention identifies a 
"flow," that is, a sequence of network messages that occur as 
a result of a requested process such as reading a file, 
sending an e-mail message, browsing a web site, initiating a 
file transfer, making a database query, etc., and routes the 
packet accordingly, thereby establishing a "virtual 
connection" at Layer 4 and above. The invention is further 
adapted for "application flow switching, " wherein the 
invention classifies received frames into flows based not only 
on the Layer 2 MAC or Layer 3 network address, but also on the 
information contained in higher layers, even up to 
"Application" Layer 7 of the OSI model. Thus, the invention 
can differentiate between flows that result from web browsing 
and flows that result from a file transfer or database query, 
even though both may use the same Layer 3 protocol. 

In the preferred embodiment, this is accomplished using a 
combination of hardware and software optimized for speed or 
for flexibility at their respective functions. Thus, 
dedicated "silicon" or gates at the chip level are employed to 
extract rapidly information from the data link headers 
corresponding to the relatively few data link protocols such 
as Ethernet, Fast Ethernet, and Frame Relay, and from the 
network headers of the relatively few network protocols such 
as Internet (IPv4, IPX, IPv6), SNA, and DECNet, while 
application protocols in up to 128 bytes of header information 
are recognized by fast pattern matching software. By looking 
at the application header, the switch can make "intelligent" 
decisions about quality of service to be applied to a 
particular flow or stream of packets (such as e-mail, which is 
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priority-based, as opposed to multimedia, which is bandwidth- 
guarantee -based) and can keep all connections while backing 
off of all applications fairly. 

By using internally standard or " canonical" headers 
including data link and network information deduced or 
inferred at the port interfaces, and comparing hashed versions 
of the canonical headers to identify the packets to flows with 
common flow rules, the invention very efficiently establishes 
a virtual connection between the appropriate ports associated 
with a given flow. This feature allows the system to be 
u frame or cell "-independent and to route ATM traffic as not 
heretofore done. 

In the preferred embodiment, thousands of transmit queues 
are possible (pointing to data packets in fast storage) that 
allow thousands of connections as well as different qualities 
of service to be attached to individual queues. 

The "intelligence" of the system in tracking packets 
according to the flow allows "cut through" flow, that is, the 
output from a port of portions of a data packet stream even as 
portions of the data packet stream are entering a port. Many 
other intelligent functions are possible because of the 
flexible and scalable architecture of the system using 
interface ASICs (application-specific integrated circuits) to 
"canonicalize" Layer 2 and 3 header information, a high speed 
bus, a queue manager ASIC which rapidly implements queuing 
decisions of a fast relay engine ASIC, and a background engine 
ASIC that monitors the flow connections. 

DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram of a preferred embodiment of 
the invention. 

FIG. 2 is a block diagram of the media interface ASIC 
(MOM) of the preferred embodiment of the invention. 

FIG. 3 is a block diagram of the queue manager ASIC (QM) 
of the preferred embodiment of the invention. 

FIG. 4 is a block diagram of the relay engine ASIC (RE) 
of the preferred embodiment of the invention. 
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FIG. 5 is a schematic diagram of the data flow of the 
preferred embodiment of the invention. 

FIG. 6 is a general flow diagram of the processes used in 
the preferred embodiment of the invention. 
5 FIG. 7A shows the data structure of a canonical header 

used in the preferred embodiment of the invention. 

FIG. 7B shows the data structure of a portion of the 
canonical header used in the preferred embodiment of the 
invention. 

10 FIG. 7C shows the data structure and possible entries of 

another portion of the canonical header used in the preferred 
embodiment of the invention. 

FIG. 7D shows the data structure and possible entries of 
another portion of the canonical header used in the preferred 
15 embodiment of the invention. 

FIG. 8A shows the data structure of another portion of 
the canonical header used in the preferred embodiment of the 
invention. 

FIG. 8B shows the data structure and possible entries of 
20 another portion of the canonical header used in the preferred 
embodiment of the invention. 

FIG. 8C shows the data structure and possible entries of 
another portion of the canonical header used in the preferred 
embodiment of the invention. 
25 FIG. 9 is a block diagram of the high-speed bus used in 

the preferred embodiment of the invention. 

FIG. 10 shows the differential character of the bus lines 
of FIG. 9. 

FIG. 11 is a schematic of a transmit circuit used on the 
30 bus shown in FIG. 9. 

FIG. 12 is a timing diagram of the transmit circuit of 
FIG. 11. 

FIG. 12A is a composite timing of the transmit circuit of 
FIG. 11. 

35 FIG. 13 is a schematic of a clock delay circuit used in 

transmission on the bus shown in FIG. 9. 

FIG. 13A is a timing diagram of signals on the circuit 
shown in FIG. 13. 
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FIG. 14 is a detail of the circuit shown in FIG. 13. 
FIG. 15 (Table 1) shows the possible values and meanings 
of a control bit used in the bus shown in FIG. 9. 

FIG. 16 shows a sequence of control bits shown in FIG. 

5 15. 

FIG. 17 is a block diagram showing the token ring 
arbitration used between the interface chips shown in FIG. 1. 

FIG. 18 shows a sequence of cell transmissions used in 
the preferred embodiment of the invention. 
10 FIG. 19 shows a pointer-register structure used in the 

preferred embodiment of the invention. 

FIG. 20A shows the data structure of a hash table entry 
used in the preferred embodiment of the invention. 

FIG. 20B shows the data structure of another hash table 
15 entry used in the preferred embodiment of the invention. 

FIG. 21 is a timing diagram for the control signals used 
on the bus shown in FIG. 9. 

FIG. 22 shows possible values and meanings of control 
bits used on the bus shown in FIG. 9. 
20 FIG. 23 shows as an example a sequence of control bits 

that may be seen on the bus shown in FIG. 9. 

FIG. 24 shows diagrammatically the cell transmissions for 
possible cells transmitted on the bus shown in FIG. 9. 

FIG. 25 shows the possible values and meanings for codes 
25 used on the bus shown in FIG. 9. 

FIG. 26 shows the data structure of a field of the 
canonical header used in the preferred embodiment at different 
times . 

FIG. 27 shows details of the data structure of one of the 
30 subfields shown in FIG. 26. 

FIG. 28 shows the data structure of a temporary "burst" 
header used in the preferred embodiment of the invention. 

FIG. 29 shows a set of linked descriptors mapped to a 
data packet used in the preferred embodiment. 
35 FIG. 29B shows a set of linked descriptors used in the 

preferred embodiment to describe an incomplete packet. 

FIG. 30 shows the linking of descriptors used in the 
preferred embodiment to establish virtual queues. 
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FIG. 30B shows the linking to buffer descriptors of 
receive and transmit context tables used in the preferred 
embodiment to track data cells forming a packet. 

FIG. 31 is a representation of a credit-managed 
transmission system used in the preferred embodiment of the 
invention . 

FIG. 32 is a representation of a ring -pointer system used 
in the preferred embodiment of the invention to determine 
whether credits should be issued in the system represented in 
FIG. 31. 

FIG. 33 is a more detailed representation of the system 
represented in FIG. 31. 

FIG. 34 is a representation of a hierarchical queue 
system used in a preferred embodiment of the invention. 

FIG. 35 shows the data structure of a transmit context 
table entry used in a preferred embodiment of the invention. 

FIG. 3 5A shows the data structure of a field of the data 
structure shown in FIG. 35. 

FIG. 35B shows the possible service policies encoded in 
the Q SVC Policy field of the data structure shown in FIG. 35. 

FIG. 36 shows the data structure of the queue table used 
in the preferred embodiment. 

FIG. 37 represents possible links and queues in the 
transmission phase of the preferred embodiment. 

FIG. 38 shows the operation of the standby scheduler used 
in a preferred embodiment of the invention. 

FIG. 39 A represents a linked descriptor set representing 
a complete packet in memory in the preferred embodiment. 

FIG. 39B represents the delinking of the descriptor set 
shown in FIG. 39A to free the buffers described by the linked 
descriptor set shown in FIG. 39A. 

FIG. 40 is a block diagram of a DRAM control system used 
in the preferred embodiment of the invention. 

DETAILED DESCRIPTION 

The specification will be organized as follows: 

1. BlazePath™/BlazeFire™ Architecture /Chip Set 

2. Header "Canonicalization" and Packet 
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"Cellular ization" 
3 . BlazeWire™ High-Speed MAC Bus 

4. Data Flow In 

5. Queue Pointer Management and Operation 

6. Relay Engine Operations /Flow Matching (FastPath™) 

7. Transmission Scheduling 

8. Download to Interfaces/Transmission Credit Loops 

9. Ultra-High Speed RAMBUS® Operation 

10. Background Engine/Initialization/Monitoring 

1. BlazePath^BlazeFire™ Architecture/Chip Set 
The architecture of the invention, called the BlazePath™ 
architecture, comprises application layer flow switching or 
connection performed by virtually allocating (by pointers to 
high speed data buffers) incoming data packets to one or more 
of a large number of virtual queues according to decisions 
made on the basis of information in the application header of 
the packets characterizing their membership in a particular 
flow. To enhance the throughput or bandwidth of the system, a 
preferred embodiment, the AppSwitch™ application flow switch, 
makes decisions according to the initial packet (s) of the flow 
and matches a hashed version of the header information to 
identify subsequent packets of the flow. By "canonicalizing" 
the header information of the incoming flow and splitting 
lengthy frames into smaller internal cells (but keeping them 
logically connected) , the system is u cell or frame'' 
independent . 

Referring to Fig. 1, in a preferred embodiment, the 
architecture is implemented in the BlazeFire™ chipset 
connected by the BlazeWire™ MAC Bus 60. The architecture is 
centered around a 287k-gate Queue Manager ("QM") ASIC 30 
operating at 100 MHz which implements the queue-pointer scheme 
allowing 16,000,000 queues for pointers (24-bit definition) to 
locations in a high-speed data buffer 35 and 36 connected to 
the QM 30 in which incoming packets are temporarily stored. 
The queues are loaded based on decisions made by the 410k-gate 
Relay Engine ( "RE" ) or Forwarding Engine ("FE") ASIC 40 
operating at 100 MHz which includes an Argonaut RISC (ARC) 
central processing unit 387 and a FIFO 394 for packet headers 
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to be examined. The input to and output from the system is 
performed using 359k-gate 60 MHz MOM (Mil [Media-Independent 
Interface] Octal MAC) ASICs 10 and 20 daisy-chained on the 
BlazeWire™ MAC Bus 60; the MOM chips 10 and 20 may each serve 
5 two Quad physical link chips (71 and 72, and 70 and 73, 
respectively) for local area Ethernets 63 or an interface for 
a wide area network such as the Distributed Access Device 
(DAD) WAN Processor 66 servicing Tl and POTS ("Plain Old 
Telephone Service") WAN lines 69 or for a Background Engine 
10 ("BE") 50. 

FIG. 2 is a block diagram of the MOM chip, for example 
MOM chip 10, used in the preferred embodiment of the 
invention. Generally, the diagram shows Mil interfaces 65 
providing eight duplexed Ethernet ports. The receive 

15 interfaces 11 and parsers 12 receive the data packets, rewrite 
the frame headers as the canonical headers described in 
Section 2 below, and divide the resulting packets into 128- 
byte cells, which are placed in FIFO 15 by producers 13 and 
the FIFO arbiter 14, in round robin arbitration among the 

20 eight ports. Data cells not bearing a canonical header 
(packet cells following the first cell of the packet) have a 
burst header added by burst logic 17 for internal tagging of 
the data. RX Credit Manager 19 adds transmission credits 
(discussed in Section 8 below) to the headers as appropriate 

25 to inform QM that the transmit FIFO 24 can accept more data to 
be transmitted. A token arbiter 18 determines when the data 
is to be sent to the MAC Bus TX cell 76 to be transmitted on 
the MAC bus 60 to QM 30. 

Still referring to FIG. 2, data cells incoming on MAC Bus 

30 60 are directed to the transmit consumers 26 and according to 
the circuit identifiers in their canonical /burst headers. The 
data packet headers are reconstructed and transmitted by the 
transmit consumers 26 and interfaces 27, and TX Credit Manager 
28 is updated with credit information to be returned to the QM 

35 30. 

FIG. 3 is a block diagram of the QM 30 used in the 
preferred embodiment of the invention. Essentially, QM 30 is 
a collection of gates and state machines designed to rapidly 
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execute the placing of data cells on appropriate queues 
(implemented virtually by linked lists of pointers to data 
buffers) and to apply queue policies as directed by the RE 40. 
The QM is divided into three clock regimes. The interface 
5 with the MAC bus 60 through Digital Delay Locked Loop 3 02 and 
Receive Interface 304, supplying Receive Data FIFO 306 and 
Receive Command FIFO 312, and through Digital Delay Locked 
Loop 301 and Transmit Interface 303 draining Transmit Data 
FIFO 305, are on the MAC bus clock. Data cells received are 
10 channeled directly through Dual RAMBUS® Access Cell 308 into 

the DRAMs 35 and 36 as discussed below. The DRAM Interface 
307, operating on the DRAM clock, coordinates the operation of 
MAC bus FIFOs 305 and 306 as well as Header Out FIFO 309 
(containing canonical header cells to be sent to the RE 40 

15 [not shown] on Header Data Interface 74), Header In FIFO 310 
(containing canonical headers rewritten at the Relay engine 
Data Interface 313 with appropriate routing information) and 
DRAM Command FIFO 311. The latter contains the decisions of 
the RE as implemented by the QM logic shown in the network of 

20 functions under the SRAM clock domain. Receive Engine 315, 
Transmit Engine 316 and Header Prefetch Engine 324 direct the 
function of DRAM Arbiter 314 to provide instructions to the 
DRAM Interface 307 to move data in and out of DRAMs 35 and 36. 
Receive Engine 315 and Transmit Engine 316 also coordinate 

25 with Free Buffer Manager 318 to allocate buffers in DRAMs 3 5 
and 36 to incoming data. EnQueue Manager 319 and DeQueue 
Manager 312 coordinate with Header Prefetch Engine and the 
Receive Queue State (head and tail of receive queue pointers, 
discussed in Section 5 below) 320, to determine, among other 

30 things, when cells containing canonical header data should be 
sent to the RE 40 for pat tern -matching and the corresponding 
packets taken off the receive queue. The Header Prefetch 
engine 324 coordinates with the Relay Engine Context 326 and 
the Instruction Dispatch Manager 327, which receives 

35 instructions from RE 40 via interface 75, Relay Engine 
Instruction Interface 329 and the Relay Engine Instruction 
FIFO 328. Circuit Poller 317 polls the Transmit Engine 316 
circuit by circuit to transmit cells and coordinates with the 
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SRAM Arbiter 322, which through the SRAM Interface 323, 
accesses linked lists of buffer pointers ("descriptors") in 
SRAM 32 to track component cells of the packets as they are 
received and transmitted on one or more queues. These 
operations, where appropriate field mappings are hard-wired, 
provide for .a great deal of flexibility in scheduling and 
routing executed at very high speed. 

FIG. 4 is a block diagram of RE 40. A primary function 
of the RE 40 is to examine canonicalized packet headers 
received at interface 74 from the QM 30 and to determine 
rapidly whether the packet belongs to a known flow and to 
provide instructions accordingly on interface 75 for 
appropriate scheduling (quality of service) . A CPU Core 387 
(implemented with the ARC processor) contains an instruction 
cache 386 and a data cache 385 and communicates with the Code 
and Data DRAM 42 through the DRAM Interface 384 (which also 
accepts instructions from the BE 50 over a low speed bus 62 
and the DMA 383 at initialization) . String Compare 

Coprocessor 389 is used to aid the pattern recognition used to 
match a packet and flow. Generally, a canonicalized packet 
header entering the RE 40 is pre-processed by the Hash 
Preprocessor 3 99 in parallel with being MUXed into Data FIFO 
394 by MUXIn 394. The results of the parallel hashing are 
placed in Hash FIFO 393 and compared by the Hash Lookup Engine 
392 with contents of the on-board Ll Cache of the Hash Table 
(of known hashes of header information associated with 
particular flow characteristics) 391. If no match is found in 
the Ll Cache 391, the Hash Lookup Engine will look to the 
entire Hash Table stored in Lookup SRAM 45, accessed through 
SRAM Interface and Arbitrator 388. Trie Search Coprocessor 
390 is used to find the proper flow parameters in situations 
(discussed below) where the fast pattern matching is not 
appropriate or fails. With the flow parameters determined, an 
appropriate instruction is issued by CPU 387 into the 
Instruction FIFO 395 and processed by Instruction Push 396 
multiplexed with any data from Data FIFO 394 by MUXOut 397 
across interface 75 into the QM 30. 
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FIG. 5 shows a general schematic of the operation of the 
preferred embodiment of the invention from the queue 
management point of view. Data on MOM Receive Ports 15' are 
directed into the QM Main Receive FIFO 3 30. Also enqueued are 
data from WAN (Tl and POTS) port receive queues 69' processed 
under protocols 66' and under the direction of DAD Management 
66" into a DAD Ethernet transmit queue 348' to appear on a MOM 
receive port 348. Data cells in the Receive FIFO 330 are 
placed in the main system packet memory DRAMs 3 5 and 3 6 while 
the canonical headers are forwarded in a FIFO 3 94 to the QM 30 
where FastPath™ processes are applied to enable appropriate 
queuing of packets on per flow, per priority and per port 
queues 332 (static priority, as discussed below) and 333 
(weighted robin priority, as discussed below) to be 
transmitted to the MOM Transmit Ports 24' (or the DAD 66 to be 
distributed on circuit queues 350 for further distribution to 
Tl and POTS Port Transmit Queues 69") for transmission. Fine 
tuning of scheduling may be achieved using Quality of Service 
Scheduling Process 33 6 relative to per flow queuing using 
Scheduled Queues 336 as "intermediate" queues. A Management 
Queue 337 is also provided with a Management Operations 
Process 338 operating on weighted round robin queues 333. A 
Monitor Queue 334 is also provided for network monitoring 
information to be transmitted over Mils 24'. On the BE 50 
side, data placed on the MOM Port Transmit Queue 339 is 
transmitted over Mil (100 Mbit Ethernet) link 64 into the BE 
Receive Queue 341. The Background Engine Main Forwarding 
Process 342 passes information into the BE Transmit Low 
Priority Queue 346 or the Management Queue 343 which is 
serviced by Management Operations Process 344 to develop data 
(including instructions) to be placed on BE Transmit High 
Priority Queue 345. Both BE Transmit Queues are drained into 
the MOM Port Receive Queue 347 via link 64 to be placed on the 
QM Receive Queue 330. 

FIG. 6 is a generalized flow diagram for the process of 
the invention. It is to be understood that the processes 
occur simultaneously along various points in the diagram for 
different cells. Because the preferred embodiment of the 
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invention divides often lengthy incoming Ethernet frames into 
cells for subsequent reassembly, it is important in the 
embodiment to characterize the cells relative to the packet 
from which it originated. A received cell may be a -start of 
packet" ("SOP") a -middle of packet" ("MOP"), an "end of 
packet" ("EOP"), or include a single packet as a "start and 
end of packet" ("SEP"). Because reception and transmission of 
data packets in the preferred embodiment is executed on a 
circuit-by-circuit basis, and a circuit is defined as a 
logical connection preserving the order of packets, cells of a 
packet on one circuit may be interleaved with cells of a 
packet on another circuit, for example on the MAC bus, but 
cells received on the same circuit must be transmitted in the 
same order. Thus, in FIG. 6A, with time going forward from 
top to bottom, an SOP 371 is received from Circuit 2, then an 
SEP 372 from Circuit 1, an SOP 373 from Circuit 3, an MOP 374 
from Circuit 2, an EOP 376 from Circuit 3, an SOP 375 from 
Circuit 1 and an EOP 377 from Circuit 3, in order of 
appearance on the MAC bus . 

Referring to the generalized process shown in FIG. 6, in 
operation 351, a packet is received at an Mil and is split at 
operation 352 into cells by MOM 10 or 20 (referring to FIG. 1) 
which also adds canonical headers (and possibly burst 
headers) . The cells in MOM Transmit buffers are arbitrated on 
the MAC bus in operation 353 and stored in DRAM for later 
transmission in operation 354, which also includes the 
development of a procedure to associate the cells with the 
original packets, such as the link-list of virtual packets 
used in the preferred embodiment of the invention. If the 
cell is an SOP, a decision 355 is made to send the cell to a 
pattern matching procedure wherein the cell is hashed 356 and 
then matched 357 against known hash results associated with 
previously identified flows. If there is no match (possibly 
after several matching procedures) , a new flow or exception is 
noted 358. In either case, an appropriate header is written 
354 to appropriately schedule and route the packet. In the 
preferred embodiment, the scheduling is done by assignment of 
the packet to a queue associated with a specified quality of 
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service and a particular circuit. A cell on a queue is 
transmitted 360 at the appropriate time, the process possibly 
including a rewriting of the headers. If the transmitted cell 
was an EOP, the packet is dequeued 361 from the circuit and if 
5 there are no other requirements for transmission of the packet 
(no more owners 362), the data buffer is released 363. This 
process may be further generalized and implemented in a 
diverse ways. 

The flow of data through a preferred embodiment of the 

10 invention is presented below in further detail, which includes 
additional inventions. 

2. Header "Canonicalization" and Frame 

"Cellular! zation" 
Upon receiving a data packet on a physical link, the 

15 inventive network switch takes the Layers 2 and 3 headers of 
incoming packets (dropping any Layer 1 packet preamble) and 
converts it to canonical form. The invention further breaks 
variable -length packets into "cells" of a maximum convenient 
length for communication on the high-speed internal bus. This 

20 allows data packets of different lengths with different Layer 
2 and 3 header formats, such as Ethernet w frames" or ATM 
"cells," to be routed by the same switching process and 
apparatus. The "canonicalization" of the header also aligns 
the header along 4 -byte boundaries that are convenient for 

25 processing. The example here is for Ethernet frames, but is 
applicable to ATM cells with appropriate modification in the 
terminology and the interface ASIC. 

Referring to FIG. 1, a frame of information is received 
by the MOM 1 chip 10 via one of the eight ports shown. The 

30 physical link Layer 1 processing is handled in the preferred 
embodiment by dual "of f -the-shelf " Quad PHY integrated 
circuits (such as available from Lucent Technologies) , each 
handling the transmit/ receive electronics of 10-Base-T (10 
Mbit/sec) or 100-Base-TX (100 Mbit/sec) Ethernet. One of the 

35 ports, e.g., from MOM 2, may be connected by internal or 
external 10 Mbit Ethernet to a DAD integrated circuit 
including an off-the-shelf WAN processor (such as available 
from Motorola) , which in turn interfaces with Tl and POTS 
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lines via modem. Together, these form a QuadServe™ WAN access 
module . 

Referring to FIG. 1, a frame or packet of information in 
the form of a data stream forming a message is input to a 
physical circuit 70 and then received by the MOM 1 chip 10 via 
one of its eight ports. FIG. 18 schematically illustrates the 
organization of a typical packet format. There may be a 
preamble 620, followed by a data link Layer 2 header 622, 
which contains information to bridge the packet, a network 
Layer 3 header 623, which contains information to route the 
message, and an application header 624, which contains 
information about the application for which the data is used. 
The headers are followed by the data itself 625, and, 
occasionally, there is a trailer 626, which usually is 
superfluous and not used. 

The MOM 1 chip, preprogrammed in hardware in the 
preferred embodiment to recognize a variety of Ethernet 
protocols, drops the preamble and trailer, reads the Layers 2 
and 3 headers from the received frame, and generates a 
canonical header of twenty-eight bytes, FIG. 7A. Having a 
buffer capacity of 256 bytes per port, the MOM 1 segments the 
frame data into cells of 128 bytes each (other cell lengths 
may be used in other embodiments) . 

Immediately adjoining the canonical header, Layer 3 
(network) header information as received is stored. The Layer 
3 header always starts at a multiple of four bytes from the 
start of the cell since the canonical header is 28 bytes. 
Important fields within the Layer 3 header are aligned at 
four-byte boundaries generally. This makes the processing of 
these fields very efficient for 32-bit processor /memory 
architectures . 

Other header information from the higher layers, 
including the application layer, follow the Layer 3 header. 
The canonical header is placed at the beginning of the first 
cell of each frame or packet received and is used by the RE 40 
to route or bridge the packet. When a packet in the form of a 
stream of cells is sent to the MOM for transmission, the MOM 
reconstructs the appropriate headers, preambles and trailers 
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according to the destination and protocol information in the 
transmit canonical header and begins transmitting the 
reconstructed packet on the line connected to the designated 
port. 

FIG. 7A shows the organization and content of the 
canonical header in a preferred embodiment. The first two 
bytes 430 hold the circuit identification of the circuit on 
which the data packet was received, Byte 432, DL Info, 
provides information about the Data Link (Layer 2) header from 
the original received header . FIG. 7B shows the specific 
assignments to these bits. Bit 7 indicates if the received 
frame was VLAN (virtual local area network) tagged on 
reception. On transmission, if this bit is set, the outgoing 
packet is encapsulated with a VLAN header by the MOM chip 
handling the transmission. However, it should be noted that 
packets received with VLAN tags are not necessarily sent out 
with VLAN tags and vice-versa. 

Bits 6 and 5 of FIG. 7B indicate how CRCs (cyclical 
redundancy checks) are to be handled. FIG. 7C is self- 
explanatory. Of note is that when the outgoing frame is 
different from the received frame, then a new CRC must be 
generated, but if the original frame is simply forwarded, then 
the CRC may not change, hence there is need to retain the old 
CRC or generate another CRC. Bits 4 and 3 are unused and left 
as zeros. FIG. 7D shows the encoding for bits 2, 1, and 0 
which identify the data link packet format. 

The canonical header NL Info field 434 contains network 
layer information. FIG. 8A shows the meaning of the eight 
bits in the NL Info. Regarding reception: bit 7 true indicates 
that the destination address (DA) of the received information 
is the address of the bridge group associated with the circuit 
on which the packet was received; bit 6 true indicates that 
the DA is the system's address for the port; bit 5 true 
indicates that the DA is an address that has been pre- 
conf igured by the invention as a "well-known address," such as 
one associated with a network control protocol. On 
transmission this bit is ignored. On transmission, if bits 7 
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and 6 are set, the appropriate source address is put on the SA 
field. 

Bits 4-0 identify the Layer 3 protocol of the packet. 
FIG. 8B identifies those protocols preprogrammed into the 
invention. These can be extended as new protocols are 
developed and need to be handled efficiently by the system. 

The Time Stamp four bytes 138 contain the time at which 
the packet will expire. The QM enters the time that the 
packet will expire when it receives the canonical header as 
part of the first cell of a packet. The QM upon transmitting 
a packet will check if the current time is greater than the 
time stamp value in the canonical header. If so, the data 
link device is directed to not transmit the packet and count 
it instead. When first generated by the MOM, this field 
contains cell information described in the "Data Flow In" 
section below. 

The two-byte receive circuit identification (Rx Ckt Id) 
identifies the circuit on which the packet is received. The 
QM copies the receive circuit identification from the Ckt Id 
field 43 0 first supplied by MOM 1 before overwriting the Ckt 
Id field 430 with the circuit identification of the circuit on 
which the data is retransmitted. The receive circuit 
identification is thus retained for later use (such as for 
management and RMON functions by the BE 50) . 

DA is a 48-bit Layer 2 (MAC) destination address of the 

received packet. 

SA is a 48-bit Layer 2 (MAC) source address of the 

received packet. 

VLAN tag is a two-byte field to accommodate a packet 
received with an Ethernet 802. 1Q tag. The VLAN tag bit in the 
DL Info field is also set, as described above. The MOM chip 
handling the transmission of this packet will tag the outgoing 
packet . 

P-Type/len is a two-byte field containing the protocol 
type/ length field. In this preferred embodiment, if the value 
is greater than 1500 (decimal) this field represents a 
protocol, and if the value is less than or equal to 1500, this 
field represents a length. Protocol is captured in the 
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Protocol Kind subfield of the NL Info field. If the protocol 
is not so configured, the Protocol Kind subfield of the NL 
Info field would indicate Unknown (0) and the P-Type/len field 
would have the value. For example, if the packet was in the 
Ethernet 802.3 format, this field would contain the length 
which could be used for validity checks with length in the 
Layer 3 header. 

The XX bytes may have other information based on the 
packet format of the received packet. FIG. 8C shows the 
contents of the XX bytes for the different DL format types. 

3. BlazeWire™ High Speed MAC Bus 

The received frame, reorganized into one or more cells, 
the first cell containing the canonical header and higher 
layer headers, is communicated to and from the QM on a high 
speed MAC bus called BlazeWire™. 

The present design of BlazeWire™ is a full-duplex, 
clocked bus of ten signals and a clock signal each way between 
two large integrated circuit chips. The clocking protocol 
allows data cransmission on the bus to be self-f raining , 
asynchronous and non-aliasing. All the signals are 

differential signals between two conductor runs with the 
inherent transmission lines properly terminated. In this 
preferred embodiment, the electrical characteristics of the 
differential drivers and receivers are as substantially 
described in the low voltage differential standard (LVDS) 
ANSI/TIA/EIA-644. The differential signal voltage is about 
two hundred and fifty millivolts (250 mv) , and the cable 
terminations and physical signal paths are arranged and 
designed to accommodate high speed operations over the bus. 
The bus is organized as a chain running from one large chip 
(MOM or QM) to another. A separate daisy chain token passing 
scheme is implemented as discussed below to control the access 
of the chips to the bus. The electronic design of the bus 
compensates for the practical variations inherent in different 
production runs of chips from possibly different 
manufacturers, supply voltage variations, and temperature 
variations. In preferred embodiments the speed of the bus can 
run upwards to the gigaHertz range. 
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The ten signals are composed of eight data, one parity, 
and one control. The data are placed on the lines on both the 
rising and falling edges of the clock signal. Since the data 
is placed on the signal lines at the clock transitions, the 
signals should be read at the receiving end at or very near 
the center of the clock signal. This allows any overshoots 
and any other signal delays or other anomalies to settle. 
Since the data is loaded onto the signal lines at both clock 
signal transitions, it is critical to have a symmetrical clock 
with minimum skew between the clock edges and the data being 
placed on the bus. The present circuitry provides a feedback 
mechanism for monitoring and finding the center of both phases 
of the clock signal, and furthermore to provide a symmetrical 
clock for the signals being sent out on the continuation of 
the bus through the chip. 

FIG. 9 diagrammatically shows the basic signal flows 
between two sub-systems represented as MOM 1 and MOM 2 with 
twenty signal lines, a group of ten each way, and a clock with 
each group. FIG. 10 shows the differential character of each 
of the twenty-two lines. Differential drivers and receivers 
as known in the art are properly terminating the transmission 
lines in their characteristic impedance to maximize signal 
fidelity and minimize ringing. Other termination schemes such 
as on the drive side may be used to advantage in other 
embodiments . 

FIG. 11 is a schematic of the circuitry by which one of 
the ten data bits is output from one of the MOMs. The 
circuitry is essentially duplicated for the other data bits. 
This circuit implementation maximizes clock symmetry and 
minimizes skew. The A data 462 is to be placed on the output 
466 followed by the B data 464. The A data is latched in the 
flop 468 and presented to the logic array. Consider that the 
prior B data has remained in the latch 472 and is input to the 
logic array 460. The logic array is arranged to load a signal 
into the latch 474 which provides, when it is "exclusive 
or'ed" with the signal that remained in latch 476, the A 
signal at the output of the gate 466. On the next clock edge 
a similar operation provides the B data signal at the output, 
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the B data 464 is latched 472 and Exclusive or'ed" with the 
prior signal in latch 474 such that the "exclusive or" of the 
data in latch 476 will provide the B signal at the output of 
the "exclusive or" 466. FIG. 12 is a simplified timing 
5 diagram of the above. 

FIG. 12A shows a composite timing chart of the bus clock 
and the ten data lines on the bus between MOMs 1 and 2. FIG. 
12A shows the transferring of eight consecutive bytes (plus 
parity and control) on each edge of the clock signal. 
10 When the signals are received at the MOM or QM, FIG. 13 

shows the MOM's circuitry which is used to provide a delayed 
clock with an edge at the center of one phase of the received 
clock. Another similar circuit is used to provide a delayed 
clock with an edge at the center of the other phase of the 
15 received clock. These centered clocks are used to latch the 
data into the receive MOM and will be the basis for the 
symmetrical clock used to send out signals from the MOM. The 
received clock 80 becomes the data input to the latch 482 and 
latch 484. A delayed clock DLYA (a delay version of the input 
20 clock) latches the clock signal 480 into the latch 482 whose 
output is SAMPLE CLK A, and a delayed clock DLYB latches the 
clock signal 480 into the latch 484 with an output SAMPLE CLK 
B. The DLYA and DLYB are delayed by the control logic by a 
programmable amount. Both of these SAMPLE CLKs are fed back 
25 to a control logic array 90 through circuitry designed to 
synchronize the signals. In operation, the control logic can 
program when the DLYA occurs. In this way, the DLYA might 
latch the clock 480 signal when it is low which the control 
logic can determine by the SAMPLE CLK A signal. The control 
30 logic continues to set different delays until the clock 480 
signal goes high. In a similar manner, the control logic 
continues to set different delays until the clock signal goes 
back low. As before, the control logic determines this 
condition from monitoring the SAMPLE CLK A signal . With 
35 reference to FIG. 13 A, once the control logic has found the 
first rising edge 480' and the falling edge 480" of the clock 
signal 480, the control logic "knows" and can set the DLYA 
rising edge 486 at the center of the positive phase of the 
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clock 480. This DLYA rising signal will be, effectively, the 
rising edge 486' used to latch data on the next successive 
positive phase of the clock 480. During the time that the 
centering of the DLYA signal, the actual data being received 
at the time 486, FIG. 13A, is latched by the DLYB, FIG. 13, 
signal which had previously been centered to the positive 
phase of the clock 480. The previous centering of the DLYB 
was accomplished in the same manner as described above using 
the SAMPLE CLK B feedback signal and the DLYB delayed signal. 
In this embodiment, while one delayed clock is latching data, 
the other delayed clock is being centered for use at some 
later time. 

The circuitry of FIG. 13 is duplicated to precisely 
measure the center of the negative phase of the input clock 
signal in order to latch in the data on the opposite phase. 
FIG. 13 shows the DLYC rising edge 489 precisely at the center 
of the negative phase of the received clock. As previously 
described, the DLYC clock is being centered during one 
negative phase of the clock 480 while the other (DLYD not 
shown) is latching data, and the DLYD will be centered while 
the DLYC clock latches data. 

FIG. 14 shows parts of the delay circuitry. The IN 
signal 494 is delayed by one gate 495 and input to the "and" 
gate 496. If the control 1 signal is a logic one the signal 
traverses gate 496 and is output via the "or" structure 498 
and becomes the output signal delayed by the three gate delays 
— 495, 496, and 498. This delay is considered as a one unit 
delay. If the control 1 signal is a logic "0" and control 2 
signal is a logic "1", the IN signal travels through gates 495 
495', 496', 498' and 498. This path is longer by two gates, 
and the IN signal is considered to have gone through two 
single unit delay circuits. Each single delay unit adds two 
gate delays. If the control logic allows the IN signal to 
reach the three gates 500, and the control X signal is a logic 
one, the IN signal will go through an incremental of four 
gates — the three gates 500 and the gate 504 (gate 502 being 
the common path duplicated in each delay circuit and disabled 
in prior delay circuits) . This circuit adds four gate delays 
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and forms a two unit delay. A four-unit delay (not shown) 
will replace the three gates 500 with seven gates, therefor 
adding an increment of eight gate delays or four unit delays. 
In this preferred embodiment, there are thirty-two single-unit 
delays, sixteen two-unit delays, and sixteen four-unit delays. 
The arrangement in this preferred embodiment allows an 
arithmetic-like progression of delays up to a total of 128 
unit delays which may be selected. In other embodiments other 
arrangements of delay circuits may be selected and other known 
delay circuits may be used to advantage. In this preferred 
embodiment, for expected manufacturing processes used to build 
the circuitry, and for expected temperature and supply voltage 
operation, a single unit delay will be about 0.15 nsec. It is 
expected that the variation of one unit delay may run from 
0.08 to 0.3 nsec depending on the above mentioned parameters. 

FIG. 15 (Table 1) is a table indicating the use of the 
control bit in this preferred embodiment. The bit is used for 
framing purposes. In the timing diagram of FIG. 12A, eight 
bytes are transferred on each clock transition marked by eO- 
e7. Table 1 shows the value of the control bit for the even 
numbers transitions, eO, e2, e4, and e6 . The combinations 
indicate the allowable functions shown in the rightmost 
column. If the control bit is zero in each of the even 
transitions the bus is idling. Any of the combinations shown 
in rows 510 signal that the data on the data lines is a valid 
frame. In particular, since the value at the e6 time is 
always zero and the value at eO time is always one for a valid 
frame of data, the system looks for a zero to one time 
sequence of the control bit. The one is assumed at eO, and if 
the combinations shown in rows 510 exists, the framing of the 
data shows a valid set of eight bytes. 

The values of rows 510 are selected to ensure that no 
aliasing of valid frames of eight data bytes can occur. The 
valid control bit sequence combinations — the rows 510, in 
FIG. 15 — will always have a zero then a one, with no other 
zero/one patterns in a valid frame. FIG. 16 shows that the 
pattern of control bit values at the even clock transition 
shows frame 512 as invalid since there is another zero /one at 
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e2 and e4 for that frame 512. However, the frame 514 is valid 
as is frame 516. In practice, the value of the control bit is 
measured at each receive clock phase and a zero to one 
transition separated by clock phase is monitored. When such a 
transition occurs, the one is treated as being in the eO time 
slot and the monitoring of frame validity is based on that 
relative timing. 

Transmission of data from the MOM chips to the QM is 
arbitrated by a token ring in the preferred embodiment. With 
reference back to the system block/schematic diagram FIG. 1, a 
token ring arbitration path 61 is shown between MOM 1 and MOM 
2 . The token ring is a looped signal where a chip has the 
token when there is a logic difference between the incoming 
token signal and the outgoing token signal. In FIG. 17, there 
is no net inversion within the chips, so there is an inverter 
in the path so that at initialization one chip, in this case 
MOM 1, will be guaranteed to have the token and be in control 
of the bus. When a chip has the token it can send its own 
data over the bus, whereas when the chip does not have the 
token, it must wait for the token while other data are simply 
passed through the chip. When a chip has the token it will 
send out all the data needing to be sent by that chip before 
releasing the token. If MOM 1 has the token, it is passed to 
MOM 2 by MOM 1 changing the state of its output signal 61. 
MOM 2 then has the token. 

This token passing may be extended to multiple devices by 
connection of the single token output signal of one device to 
the single token input signal of the next device. The last 
device's token output signal is inverted and then sent to the 
first device in the token passing chain. 

Implementation of the token passing at an edge or change 
of state of the information facilitates synchronization 
between different clock domains. The token automatically, by 
virtue of the edge-based information passing, remains valid at 
a device until it is recognized and then passed on to the next 
device in the token passing chain. 
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4. Data Plow In 

The MOM 1 chip 10 can store or buffer up to two cells or 
256 bytes of received data for each of the eight ports. As 
described in the "Header Canonicalization" section above, the 
5 MOM chip reads the Layer 2 and 3 headers from the received 
frame or packet and generates an initial canonical header of 
twenty-eight bytes (described further in this section) , 
followed by the network Layer 3 header and the application 
layer header in the first cell processed. 

10 The MOM 10 (or 20) transmits the cell on the high-speed 

MAC bus 60 to the QM 30 when the MOM holds the token of the 
token ring arbitration path described above. Between the 
eight ports of a MOM, arbitration is round robin. The QM 
receives the cell and stores the cell in dynamic RAMs 3 5 and 

15 36, in this preferred embodiment a RAMBUS® DRAM having two 
banks of DRAMs rapidly accessed as described in Section 9 
below. Information describing a received, stored cell is 
placed in SRAM 32 and is called "descriptors . " The canonical 
header is modified to include the Time Stamp. The modified 

20 canonical header and the rest of the header information in the 
first cell of the packet is placed in a Header Out FIFO 309 
for transfer to the RE 40. 

Because of the segmentation of frames, and the 
arbitration scheme, subsequent cells of a packet received on a 

25 circuit may be interleaved with cells of other packets 
received on other circuits. To provide information to allow 
the QM to keep track of the order of the cells of a packet, 
the MOM writes an eight-byte (octbyte) "burst" header added to 
subsequent cells of the same packet (making up to 17 

30 octbytes), corresponding to the first octbyte of the initial 
canonical header of the first cell of the packet. 

Additional information is sent on the control signal line 
or bit of the high-speed MAC bus that allows identification of 
the boundaries of the cell and the type of information 

35 contained in the cell. FIG. 21 shows the use of the control 
bit to delineate data in groups of octbytes. The control bit 
700 over eight consecutive clock phases frames eight bytes and 
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distinguishes the data. The value of the control bit is shown 
as eO through e7 in the table FIG. 22. 

In FIG. 22 the even control bits, eO, e2, e4, and e6 are 
encoded as follows: eO is always a one and e6 is always a zero 
5 to indicate that a valid group of eight bytes is received. To 
prevent aliasing of this encoding, the only values indicating 
a valid group are (for the even control bits, eO through e6) : 
1000; 1100; and 1110. The bit e2 indicates' the start of a 
cell,. and e4 indicates the start of a packet. FIG. 23 shows a 

10 possible sequence of the even control bits: group 702 is not 
a valid group, while groups 704, 708 and 710 are valid. The 
circled zero/one 708 indicates that the only possible 
beginning to a valid group must have a zero followed directly 
by a one, and there can not be another zero/one in the next 

15 two bits (e2 and e4) . 

Still referring to FIG. 22, the odd control bits are 
encoded as follows: el indicates a transmission credit (see 
discussion below) exists, e3 (code bit 0) and e5 (code bit 1) 
form a two-bit end code, and e7 (short word) indicates an 

20 octbyte containing fewer than eight meaningful bytes. The 
short word can be used at the start of a cell or at the end of 
a cell. 

FIG. 24 is a chart of several packet types that may be 
encountered. The first cell 720 of the packet may have up to 

25 sixteen octbytes, or 128 bytes. The even control bits 722 for 
the first 32-bit word (octbyte) is 1110. As shown in FIG. 22, 
this code means that this octbyte is part of a valid first 
cell of a packet. As shown, eO equal to u l" is required for a 
valid cell; e2 equal to w l" means this eight -byte transfer is 

30 the start of a cell, e4 equal to *1* means it is the start of 
a packet, and e6 must be zero for a valid cell. For the cell 
720, the odd control bits are all zeros except for bit e5 of 
the last eight -byte transfer, which is a "1". FIG. 25 shows 
the encoding of the control bits el, e3, e5, and e7 -- the odd 

35 control bits. For cell 720, e5 is a w l" and e3 is a "0" which 
decodes into "end of packet." Thus cell 720 is a one-cell 
packet (SEP) . It should be noted that this cell need not be a 
full 128 bytes long. 
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Cell 724 is a valid starting cell of a packet, and here 
e3 of the odd control bits 726 is set meaning "end of cell" 
but not "end of packet"; thus, it is an SOP cell. The next 
cell 728 is the second cell of a packet (MOP) , and all the 
cells following an SOP cell will have up to seventeen 
octbytes, including an octbyte burst header 330 added to the 
beginning of each cell. For this second cell, the last 
octbyte e3 is set meaning this cell is the end of a cell, but 
not the end of the packet. The cell 734 has e5 set in the 
last eight byte group, meaning that this cell is the end of 
the packet (EOP) , and in this instance, e7 is also set. The 
bit e7 means that the last group of eight was not filled and 
was a "short word" (as so labeled in FIG. 25), and when this 
happens, the last byte 338 contains the number of valid bytes 
in the last eight byte group. For example, if there were only 
three valid bytes in the last group, the last byte (concurrent 
with the e7 control bit) , would contain 0011, or decimal 
three . 

Regarding the transmission of cells to the QM from the 
MOM chip, the first octbyte at the start of the first cell 
contains a portion of the canonical header that is modified by 
the QM to include the Time Stamp. The entire canonical header 
is stored in the DRAM with the other headers and such frame 
data as may fit in the remainder of the 128 bytes, 

FIG. 26 shows the transformation of the first octbyte of 
the canonical header by the QM. As shown, the initial four 
bytes 740 written by the MOM, the Ckt Id, DL Info and NL Info, 
are carried forward by the QM. The second four bytes 742, 
including cell information, is overwritten by the QM with the 
Time Stamp 748. (The canonical header is sent to the RE, 
which only deals with packet policy and is unconcerned with 
cell information.) 

The first byte 744 of the cell information bytes 742 
contains the number of transmission credits being reported 
from the QM (described in the "Transmission Credit Scheme" 
section below). The second byte contains credit flags, bit 7 
being a SYNCH flag (for initialization) and bit 6 a "parent" 
flag (described in Section 8 below) . The third byte provides 
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cell information whose meanings are shown in FIG. 27. The bit 
meanings are: bit 7 indicates cell error; bit 6 packet time 
out; bit 5 a packet from the bad packet queue; bit 4 from the 
monitor queue; and bits 3-0 are selected bits from the control 
described above. Bit 3 is the packet end bit, bit 2 is the 
start of packet bit, bit 1 is the data cell bit, and bit zero 
is the transmit credit bit. The last byte in the cell 
information bytes 742 provides the cell length in number of 
bytes . 

The octbyte-long burst header used to track cells without 
canonical headers is shown in FIG. 28. Its fields are 
identical to those of the first octbyte of the initial 
canonical header except that DL Info and NL Info (used by the 
RE which only sees the SOP) is replaced by the cell sequence 
number 752 and unused space. The Ckt Id 750 is used to match 
the cell (or more specifically, its proxy, the buffer 
descriptor) with preceding cells having the same Ckt Id, which 
should have sequential sequence numbers (unless a cell has 
been discarded). Once the cell is linked by the QM with 
preceding cells (as described below) , the credits entered, and 
action taken on the other cell information, the burst header 
is no longer needed and is dropped. (A cell may be discarded 
if parity information detects an error. In such cases, at this 
time the cell and finally the packet is aborted by signaling 
the MOM chip.) A new burst header is created for the cell by 
the QM in the transmit phase, where the CKT ID shows where the 

packet is being sent. 

5. QM Buffer and Queue Structure and Operation 

Data cells received on the MAC bus by the QM are 
individually stored in the RAMBUS® DRAMs according to the 
fast-access operation described in Section 9 below, in 
addressable 12 8 -byte data buffers, with the canonical header 
intact but rewritten to include the Time Stamp, and with the 
burst header octbyte dropped. Address 00000 does not contain 
cell information and corresponds to a null -pointer . 

All data cells received on the MAC bus and stored in data 
buffers are organized in a single virtual receive queue using 
a descriptor/pointer scheme that is used for all but a handful 
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of specialized queues for exceptions. The scheme allows a 
receive queue corresponding to up to 1 Gbytes of data. 

In the descriptor /pointer scheme, data buffer 
"descriptors" in the QM SRAM, comprising two 4-byte words, are 
surrogates for the actual data stored in the buffers and are 
linked to form logical packets. Thus a descriptor assigned to 
a data buffer with data has a field in the first word 
indicating the address of the buffer in the DRAM in which the 
associated cell is stored and a field in the second word 
containing a pointer to another descriptor 802 in the SRAM 
associated with the next cell of the same packet. As shown in 
FIG. 29, a complete multi-cell packet is described by a 
descriptor "link-list," with the second word of the SOP buffer 
descriptor 801 pointing to the MOP buffer descriptor 802, the 
second word of descriptor 802 pointing to EOP buffer 
descriptor 803 and the second word of descriptor 803, 
associated with the last cell of the packet, containing a 
pointer pointing to descriptor 801, associated with the first 
cell of the packet. As shown in FIG. 29B, an incomplete 
packet has a null pointer in the second word of descriptor 
805. 

Queues are formed in the invention by a queue head 
pointer pointing to the first word of the descriptor 
associated with the first cell of the first packet in the 
queue and with a field in that first word pointing to the 
first word of the descriptor associated with the first cell of 
the next packet in the queue, and so linked reiteratively 
until the last packet in the queue, which has a queue tail 
pointer pointing to it, as shown in FIG. 30 with the receive 
queue head pointer pointing to the designator 812 associated 
with the first cell of the first packet in the queue and tail 
811 pointing to the designator 815 associated with the first 
cell of the last packet of the receive queue (the descriptors 
each map to a 128-byte buffer in DRAMs 35 or 36). As shown, 
the queued packets are not necessarily complete, but in this 
packet -oriented implementation, data cells received from the 
MAC bus are "added" to the packet to which it is identified by 
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Rev Ckt Id in the burst header, rather than at the end of the 
queue. 

In the receive operation, the QM Descriptor SRAM is 
organized into a buffer descriptor table and a receive context 
(or circuit) table. The buffer table or list has descriptors 
containing two 4 -byte words, with word 0 containing a buffer 
address of a data buffer in the RAMBUS® DRAM (hence the buffer 
table entry is an implicit buffer) , and word 1 containing a 
pointer to another descriptor in the buffer table. At 
initialization, the buffer table is a "free buffer table" the 
designator of the first free buffer to which the QM hardware 
by a head pointer points and the second word of which points 
to the next free buffer descriptor, and so reiterated in a 
link until the last free buffer designator which contains a 
null terminator in its second word. 

As a data cell is presented by the MAC bus to the QM, the 
QM extracts its circuit id from its canonical or burst header 
and checks for an entry in the receive context (circuit) table 
which yields information on the activity of that circuit. 
When an SOP is detected, an entry on the receive context table 
(8 bytes /circuit) is created and a pointer (current buffer) is 
entered pointing to the next free buffer designator. The cell 
data is written into the associated RAMBUS® DRAM buffer. The 
free buffer list pointer is moved to the next free buffer 
designator after the "current buffer" is allocated. 

If the received cell was not an SEP, the second word in 
the buffer designator points to the next free buffer 
designator, preallocating the associated buffer, and a w 0" is 
written in the second word of that next buffer entry. 

If the received cell was an SEP or an EOP, the second 
word in the buffer descriptor is set to point to the first 
buffer descriptor for the packet, and the resulting link-list 
defining the packet is de- linked from the receive context 
table . 

The cells received with the same circuit id, which may be 
interleaved on the MAC bus, are thus virtually reorganized by 
link-lists into packets, some of which may be incomplete even 
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when leading cells are transmitted in cut-through operation. 
In the latter case, as shown in FIG. 30B, the current buffer 
of the receive context table 820 points to the next buffer 
descriptor 83 3 corresponding to the buffer into which the data 
cell is to be loaded, and the buffer descriptor 833 is linked 
to the descriptors 832, 822, and 821 of the other cells of the 
packet, one of which, descriptor 832, is linked as the current 
buffer 821 of a circuit entry in the transmit context table. 
Since the circuit entry in the transmit context table provides 
routing information, the data subsequently placed in the 
buffer associated with descriptor 833 "knows where to go." 
This system of link management allows "cut- through, " that is, 
the transmission of portions of a packet while other portions 
are still being received. 

6. Relay Engine Processing/Flow Matching 
(Fast Path™) 

The receive queue of linked descriptors of SOPs waits for 
processing by the RE 40. The SOP cells themselves are loaded, 
as room is made available, into a "circular" FIFO 394 of 16 
128-byte registers processed by the relay engine. This is 
implemented with a pointer system that follows the processing 
of the SOP cells, adding cells until the register is full 
(when the send pointer "catches up" to the receive pointer in 
FIG. 19), then adding another cell only when processing of the 
cell pointed to by a head pointer is complete and dropped (and 
the receive pointer "falls behind" the transmit pointer) . 

The RE operation centers around a four-stage pipeline. 
Pipelining is a term of art used for many years, especially in 
high speed hardware designs, and will not be further discussed 
herein except incidentally. The RE's task is to determine how 
to best forward a frame flow and to provide forwarding 
information accordingly to the QM to route and schedule 
retransmission of stored packets. The four stages are briefly 
described here, followed by a more detailed description of the 
hashing and signature functions used to perform pattern 
matching to identify a flow. 

The first stage stores the full header information (the 
entire SOP cell) in a "circular" data FIFO, in parallel as the 
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header is processed by a hash engine to compute a hash and a 
signature value to perform a pattern-matching function to 
check whether the packet is part of an existing flow for which 
routing and scheduling information has already been developed. 
5 The second stage receives the Hash value which is used to 

address a Hash Table LI 391. If a valid entry is found in this 
table, the signature from the LI Table is compared to the 
computed signature of the Hashed data. If consistent, then a 
Flow Tag (not shown) from the Hash Table is presented to the 
10 next stage of the pipelined FE/RE hardware design together 
with an indication that a valid hit was found. The Flow Tag 
is a 24-bit index into a table in memory where information 
about the flow is stored. This information will include the 
circuit or circuits on which to forward the packet along with 
15 other flow related information as described elsewhere herein. 

A valid Flow Tag pointer (linking the contents pointed 
to) is the preferred result of the pattern matching functions 
described in this preferred embodiment. 

If a match is not found in LI, the search is performed on 
20 the off -chip L2 Table 45. Signatures are compared as above 
and the Flow Tag from the L2 table is presented to the next 
stage. To facilitate the next search, the L2 entry is written 
into the LI table. 

If there is no hit in either LI or L2, the computed hash 
25 and signature are presented to the next stage with an 
indication that no hit was found. 

The third stage receives the above information and 
determines if the header look-up was successful. If 
successful, the header data is updated according to the 
30 protocol rules that apply and the packet is forwarded 
according to the flow information. However, if the header is 
found to be a TCP (Layer 4 Transport Control Protocol) SYN 
packet, or an equivalent start of connection packet in another 
protocol, or if the frame is not part of a known connection 
35 flow, the packet is not forwarded according to the flow 
information. In these instances the RE acts to route the 
frame by decoding the full pre-hashed header. In the process 
it creates useful flow information and inserts a tag that 
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points to it in the L2 Hash Table using the hash and signature 
values obtained by the hardware in stage one. 

In the fourth stage of the pipeline, the header is passed 
back to the QM to be queued for transmitting on the specified 
queue according to the information supplied by the Flow Tag or 
the routing information supplied by the RE's decoding of the 
full pre- hashed header. For putting together the information 
to forward subsequent packets of the flow, the RE examines the 
application layer data in addition to the Layer 2 and Layer 3 
headers . 

In further detail, with reference to FIG. 4, when a 
packet is received, the QM 30 provides a useful header (as 
determined from the NL field) which may be as long as 128 
bytes to the FE/RE by loading that header data onto a dual 
ported circular buffer in the RE. With reference to FIG. 4, 
the header data is sent from the QM 100 to the MUXIn 102 and 
placed on a FIFO stack DF in the RE 40. The RE uses the 
network link byte to index into a previously stored ordered 
data array of 128-bit entries, where each bit corresponds to 
one of the full received header data bytes. The bytes that 
correspond to the bits with a one are extracted and processed 
by the hash and signature functions. The byte string is padded 
at the end with zeroes to provide a string that is an even 
multiple of four bytes. In this preferred embodiment, up to 64 
of the 128 header bytes can be processed by the hash /signature 
operation, but fewer or more can be used to advantage in other 
preferred embodiments. 

The hash and the signature functions are identical except 
that different multipliers are used. But, in other preferred 
embodiments, other combinations of different multipliers and 
different divisors may be used. to advantage. 

With reference to FIG. 4, the Hash Preprocessor 399 
inputs the selected bytes from the 128 bytes of the header 
data. The selected bytes form a number (n) of 32-bit words 
(multiples of 4 bytes, as noted above) . The bits in this 
sequence of 32 bit words are treated as a polynomial in the 
Galois Field, GF[2] — a Galois Field of 2 (Galois Field is 
known in the art) . In this preferred embodiment, the 
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polynomial is multiplied by a random 32-bit polynomial, and 
then divided by a carefully chosen polynomial of order 32 
resulting in a 32 -bit remainder. The divisor used above is 
selected to be both irreducible and primitive (irreducible and 
5 primitive are terms known in the art) . A subset of the 
remainder bits are used as the actual index into the hash 
table. Bits 5 down to 0 are addresses directed into the on- 
chip LI cache 391. Bits 16 to 1 are used to address the 64K 
locations in the off -chip L2 RAM 45. 
10 The divisor used in this preferred embodiment is 

x 32 +x 7 +x 5 +x 3 +x 2 +x+l, although others may be used, provided they 
are both irreducible and primitive. 

The contents of the Hash Tables which identify the Flow 
Tag and/or the destination of the incoming frame are organized 
15 as follows: 
Hash Table 1 contains 64 words each of 64 bits, and it 
exists on chip to optimize the return of the value in the 
common occurrence where only a small number of flows are 
active. Larger tables can be used. In each word, see FIGS. 
20 20A and 20B, bits 31-24 form a status where bit 31 being true 
indicates a valid entry. Bits 0-23 form a 24-bit Flow Tag 
where information about the particular flow is stored. The 
tag is a pointer to information about the circuit or circuits 
to which the packet will be forwarded. Obtaining the Flow Tag 
25 is the primary task of the RE. The Hash table also contains 
the 32-bit signature at bits 63-32, which is used to ensure 
that no collision has occurred and the result is valid. In 
order to further ensure the validity of the Flow Tag look up, 
the pre-hashed header data is stored so that unambiguous 
30 identification may be performed. 

If there is no match in the Ll Hash table, the system 
will use the hashed result bits 16-0 to index into the 64k 
Hash Table L2 . Each location will have a 64 bit width. Bit 30 
is a Hash Bucket pointer wherein, if this bit is a zero, the 
35 bits in L2 table are organized functionally as in the Ll 
table. If there is one valid entry at this Hash Address, the 
system takes L2 bits 0-23 to be an index into a flow table to 
obtain a flow tag. See FIG. 20B. If there are no valid 
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entries at this Hash Address, L2 bit 31, the Valid Bit, is set 
to a zero. If there are two or more entries at this hash 
address, then status word bit 30 is set to a one and the 
system takes the L2 bits 55-36 as a pointer to the Hash 
Bucket . 

The Hash Bucket holds up to eight aliased addresses of 
64-bit words. If the collision bit 29 is a one an aliased 
condition persists for both the hash and the signature 
operations and no further resolution will be performed by the 
hash mechanism, as no useful information can be obtained. At 
this point the two conflicting flows are handed back to the 
processor to perform a Trie search for routing information. 
The eight words in the Hash Bucket are searched sequentially, 
and to facilitate this search the addresses are sequential 
starting at the lowest index into the table. If more than 
eight entries are directed to the Hash Bucket, the system 
reverts and the overflow are searched via the Trie routine. 
The Trie search uses a co-processor 390 and is organized as a 
large Trie database for routing and bridging. 

The occurrence of signature and/or hash collisions can be 
monitored, and if excessive, the respective multipliers can be 
changed. Such changing results in a better randomization for 
the given set of addresses encountered in the network. 

The hashing and signature routine results are not used in 
certain circumstances : when a connection is initiated, as when 
a TCP SYN or an equivalent "start of connection" packet 
arrives, or when a packet is found that does not belong to a 
connection flow, or the packet is part of a high security or 
other special mode. When such conditions are found the system 
can revert to the Trie search. 

Generally processing of subsequent packets in a flow is 
accelerated by the optimization of software pattern matching 
as described above. 

The RE returns information with instructions indicating 
which queue the cells are to be placed for forwarding along 
with the addressing. The QM receives the information and 
places the cells, which are stored in linked lists forming the 
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contents of the packet which is being or was received, on a 
list to be transmitted. 

7 . Transmission Scheduling 

The RE programs the QM, developing virtually by linked 
pointers in the QM Descriptor SRAM up to 16,000,000 transmit 
queues (24 bits) with managed priority for the various 
circuits . 

The core of the transmission phase is the Transmit 
Context Table, which is organized by circuit, four four-byte 
words for each circuit as shown in FIG. 35. Word 0 contains a 
credit sync bit, seven bits 812 for transmit credits (no 
transmission unless a credit exists for the circuit), a start 
of packet bit 814, and 23 bits designating the next buffer to 
transmit (next buffer ID) . Word 1 816 contains eight flag bits 
818. FIG. 35A shows the meaning of these flag bits: Bit 7 
indicates that the packet is a single buffer; bit 6 indicates 
that the packet is bad, usually from a CRC error, and that the 
MOM should abort this packet; bit 5 indicates that the packet 
was dequeued from the monitor queue wherein the packet can be 
off loaded at some other port or to the background engine for 
traffic analysis; bit 4 indicates that the packet is "multi- 
owned" or may be transmitted to more than one circuit; bits 3- 
0 indicate the buffer length in bytes up to 128 bytes in 
groups of sixteen bytes. The remaining 24 bits of Word 1 
contain the address of the first queue (each circuit may have 
1, 2, 4, 8, or 16 associated queues). Word 2 820 in the 
transmit context table contains one bit 822 that indicates 
that a monitor queue is attached, four bits that indicate the 
queue service policy, and three bits that indicate a reference 
count. FIG. 35B shows the meanings of the four queue service 
policy bits. The possible designations are: one queue; two, 
four, eight or sixteen static queues; two, four, or eight 
weighted round robin queues; or two, four, eight and sixteen 
one-half static and one-half weighted round robin queues. As 
described below, the static queues have the highest priority, 
followed by the weighted round robin queues. Word 3 contains 
the stand-by scheduler control word, which consists of "next 
cct Id, " "parent cct Id" (used only for stand-by scheduler 
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circuits), a state bit (active or idle) and a stand-by 
scheduler interval. 

The Queue Table shown at FIG. 36, which coordinates with 
the Transmit Context Table, contains four four-byte words for 
each queue. Word 0 contains a 2-byte standby circuit ID 
(discussed below) and two bytes of queue summary bits (only in 
every sixteenth queue number) . Word 1 contains two bytes 
indicating the queue size and a 2-byte overflow counter ID. 
Word 2 contains a five-bit field indicating the number of 
standby queues and 24 bits for the head-of -queue pointer. 
Word 3 contains a 24-bit tail-of -queue pointer. 

In the preferred embodiment, it should be remembered that 
a queue is formed by linking the SOP cells starting with a 
head-of -queue pointer to the first SOP (and a tail pointer to 
the last SOP) , and new cells of a packet are added to the cell 
of the packet. Thus, referring to FIG. 37, there are four 
SOPs in queue 16 of Queue Table 850, represented by linked 
descriptors 863, and two SOPs or "packets" in queue 17 
represented by linked descriptors 864 . Incomplete packets, 
such as that represented by linked descriptors 862 may 
nonetheless be transmitted (allowing "cut -through" ) , but 
transmission will stop on the circuit when the last descriptor 
indicates that its associated buffer is empty, thereby 
preserving the rule that packet order is preserved on a 
circuit . 

The queue policy allows prioritizing and scheduling of 
transmission of data packets. Thus, under a fixed static 
priority, all the packets on a particular queue are 
transmitted before those on another. In a weighted round 
robin scheme, a certain number of packets on one queue are 
transmitted, then a certain number of packets on the next 
queue are transmitted, and so forth, this allows classes 
(queues) of traffic to have relative priorities without 
"starving" the lower priority classes. A "half-and-half 
scheme is provided in which the static queues have priority, 
and when they are served. 

A Schedule Table for the circuits in use is scanned 
continuously. As shown in FIG. 37, this is composed of a 
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Primary Schedule Table with a Primary Schedule Table A 865 and 
a Primary Schedule Table B 866 and a Secondary Schedule Table 
870. The Primary Schedule Table is located on-chip and 
consists of the two mentioned subtables, each with 64 entries. 
Slots in Primary Schedule Table A are visited once every 
Schedule Table time "tick." A Primary Table A entry contains 
a 6-bit index to an entry in Primary Schedule Table B. As 
shown in FIG. 37, any given Table B entry may have more than 
one Table A entry pointing to it. Primary Table B entries 
contain the size of the secondary table, and if the size is 
not equal to "0", then it also contains an offset into the 
secondary table 867 and the base address of the secondary 
table 868. If the size is equal to "0", the remaining fields 
are the "Use Parent Circuit" bit 871, the Parent Circuit ID 
872 and the Circuit ID 873. 

A cell transmission event is triggered when a schedule 
table entry with a Circuit ID is found. By entering the 
appropriate Circuit Ids in the Schedule Table, a cell 
transmission ordering pattern is created which effectively 
allocates bandwidth to circuits according to their respective 
proportion of transmission events. 

The hierarchical nature of the Schedule Table allows a 
wide range of rates to be programmed. This is done by 
"chaining" up to 3 levels of subtables. If the size field of 
a Primary Table B entry is not zero, this entry contains a 
pointer to a Secondary Table which is located off -chip. A 
Secondary Table 870 may have up to 255 entries, each of which 
may point to a Tertiary Table or may contain a Circuit ID. 
When table chaining is encountered, the offset field 867 is 
used to keep track of which entry is to be accessed in the 
lower-level table. At each visitation, the offset is 
incremented, modulo the table size. 

The Stand-by Scheduler (SBS) is a secondary scheduling 
mechanism. As its name implies, it schedules traffic for 
bandwidth left over from the Schedule Table. There are 2 
cases where stand-by traffic can be transmitted: (1) a 
transmit event resulted in no data sent for a circuit (lack of 
credits or lack of data); and (2) the Circuit ID programmed in 
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the Schedule Table is zero, thereby pre-allocating a certain 
amount of bandwidth to stand-by traffic. 

The SBS uses a version of the Calendar Queue algorithm, 
essentially a slotted time ring implemented as an array of 
linked lists. Each element of the array corresponds to a 
different time slot. Attached to each time slot is a list of 
circuits which are scheduled to send a cell at this time. A 
slot index advances with time. When a populated slot is 
found, a cell for the circuit at the head of the list at that 
slot can be transmitted. When a cell is transmitted for a 
particular circuit, the eligibility time for the next cell on 
that circuit is calculated and mapped to another time slot. 

Referring to FIG. 38, the Stand By Scheduler Calendar 
Table 878 is an on-chip table consisting of 64 entries. Each 
entry contains a head and tail index to describe a linked list 
of circuits attached to a particular slot. The links are 
stored in the Next CCtld field of word 3 in the Transmit 
Context Table 860. The slot index 877 advances with periods 
corresponding to the QM core clock. When a SBS opportunity 
arises, the next circuit to transmit is found by scanning 
forward from the point in time represented by the current 
value of the slot index. The next circuit to send is the one 
at the head of the list for the next populated slot. Once the 
next circuit is found, it is dequeued from the list and 
rescheduled. 

Rescheduling is performed by calculating the next slot at 
which the circuit should be sent. The calculation of the next 
slot is based on the SBS Interval field of Word 3 in the 
Transmit Context Table. This field is a 6 -bit number 
representing the number of Calendar Table slots between 
successive transmission events for the circuit. The next slot 
for a circuit is the current slot plus this interval, modulo 
the table size. The net effect of the SBS is an approximation 
of the Weighted Fair Queuing algorithm. The weight of a given 
circuit is the inverse of its SBS Interval. 

Another aspect of the Stand-by Scheduler is its ability 
to perform dynamic bandwidth allocation based on only the 
circuits which are "active," i.e., have data to send. 
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Thousands of circuits may be enabled for stand-by bandwidth. 
However, only a small number will likely be active at any one 
time. in order to more efficiently use stand-by bandwidth, 
the SBS keeps only active circuits in the scheduler. It 
receives messages from the process managing the Queue Table 
when a circuit becomes active or goes idle. The transition 
from active to idle occurs when a packet is dequeued resulting 
in all queues for the circuit becoming empty. The transition 
from idle to active occurs when a packet is enqueued to a 
circuit which has all empty queues. 

Any circuit may be scheduled using both the Schedule 
Table and the SBS simultaneously. This is useful for ATM 
Available Bit Rate ( "ABR" ) traffic . 

The "sending" in the preferred embodiment starts with the 
delinking of a packet string (which may be incomplete) from 
its queue ("dequeuing") and its linking to the current buffer 
of the Transmit Context Table 860 (as shown in FIG. 37). The 
circuit entries of the Transmit Context Table are then polled 
to send the buffer contents of the current buffer (if not 
empty) to the corresponding "circuit" 63'. Cell data is read 
from the RAMBUS® DRAMs according to the "ping-pong" scheme 
described below. 

When a packet is fully transmitted, its buffers are 
returned to the free buffer list. Completion of transmission 
of a packet is indicated when the next buffer of the transmit 
context table is directed to the descriptor 880 associated 
with the first buffer of the packet by the second word of the 
descriptor 882 of the last buffer of the packet, referring to 
pointer 883 in FIG. 39A. The free buffer manager (not shown) 
then checks whether there are other "owners" (such as for 
multicasting) by looking at the "owner" field of descriptor 

880 of the SOP, and if none (if value is one, otherwise 
decrement), as shown in FIG. 39B, it increments the free 
counter 890 by the buffer count 891 in the second word of 
descriptor 890. It moves the free buffer list head pointer 
895 from the head of the free buffer list 896 to the 
descriptor to which descriptor 880 points, namely descriptor 

881 of the buffer of the second cell, and enters in the next 
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descriptor field of descriptor 880 a pointer to the previous 
head of the free buffer list 896. As seen in FIG. 39B, all 
three buffers are thus linked at the head of the free buffer 
list. 

8. Transmission Credit Loops 

In the preferred embodiment, a hierarchical flow and 
congestion control scheme is provided by the use of multiple 
credit loops. A system of credits is established that 
indicates the ability of the MOM chip, for each of the eight 
output channels, to accept cells for transmission. As the MOM, 
for a particular channel is sending a packet, cell by cell, 
and as each cell is sent the MOM indicates, through the credit 
bits described above, that another cell can be transferred to 
the MOM chip. As shown in FIG. 31, the MOM, upon sending out 
a cell will increment the credit count 760, and as the QM 
transfers cells 762 to the MOM, the QM decrements the credit 
count 764. As noted above, the credits have a circuit ID such 
that the proper MOM channel credit is retained. In this 
preferred embodiment, as many as four transmit cells can be 
stored. The MOM has a FIFO in which the packet is reassembled 
from the cells . 

When a cell is transmitted by the MOM chip, the credit 
sent back to the QM is a credit for a maximum length cell, 
which may be 17 octbytes when in cell mode or 16 octbytes when 
in packet mode (because the MOM deletes the burst header when 
in packet mode) . However, the QM may send down something less 
than the maximum cell size. FIG. 32, which is duplicated for 
each output channel associated with the MOM chips, 
diagrammatically shows the mechanism by which the credits are 
processed in the MOM chip. There is a head pointer 770, a 
tail pointer 772," a virtual tail pointer 774, and a start of 
packet pointer 776. In this preferred embodiment there are 
512, or four full 128-byte location in the transmit FIFO. In 
FIG. 32, there are 64 slots, each slot 778 representatively 
holding one octbyte. (The 64 octbytes equal the 512 -byte 
storage capacity of the FIFO in this embodiment.) 

At initialization the FIFO is empty, and the virtual tail 
is incremented, moving it through the FIFO locations. The 
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virtual tail pointer stops when it reaches or attempts to 
reach the head pointer. Each time the virtual tail pointer 
increments, a single credit is sent via the transmit and 
receive credit managers in the MOM chip. These credits are 
accumulated in the QM for this circuit. As the MOM receives 
cells to this circuit, the tail pointer (this pointer points 
to real information representing actual cell lengths) is 
incremented. If the QM sends less than a full cell, the 
virtual tail pointer is corrected. When the MOM actually 
transmits the cells the head pointer is incremented. As the 
MOM sends out the cells the head pointer moves away from the 
virtual and the real tail pointers, opening up room in the 
FIFO. When the virtual tail pointer, which might have been 
corrected by the QM sending less than maximum cells, can 
increment a maximum cell length in the transmit FIFO, without 
wrapping the head pointer, a credit is sent and established in 
the QM. 

The other remaining pointer, the start of packet pointer, 
776, has one important function. That function is to retain 
the starting location of the start of the packet, so that if 
there is a collision on an Ethernet cable, the packet that was 
collided with can be retransmitted, in accordance with the 
published specification. 

With regard to FIG. 2, the virtual tail pointers are 
controlled by the transmit credit manager and the real tail 
pointers are controlled by the transmit FIFO "producer," and 
the "consumer" controls the header and the start of packet 
pointers. All the pointers are accessible to all the transmit 
credit manager for comparison and for issuing credits. 

FIG. 33 indicates how the MOM FIFO, a two-port, 64- 
octbyte memory, is controlled. An arbiter 780 controls the 
most significant three address bits of the FIFO from the 
"producer" side to keep track of the cells loaded from the QM, 
and the lower six bits, the total of nine bits needed to 
address the 512 locations, are controlled by the tail pointer 
782 (one shown of eight) . The virtual tail pointer 784 does 
not point to real data; it is a counter mechanism by which the 
credit manager can determine the number of credits to send to 
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the QM. Another arbiter 786 and head pointers (one shown of 
eight) control the unloading and freeing up of the FIFO as 
packets are physically sent out by the MOM chip. The head 
pointer 788 controls the lower six bits of the FIFO from the 
unloading side of the FIFO. The consumer increments the head 
pointer as the data is sent out. The head, tail and start of 
header pointers are available to the transmit credit 
circuitry. 

Referring to FIG. 26, a portion 742 of the first octbyte 
of the initial canonical header and, referring to FIG. 27, the 
burst header contain two credit flags, the xv synch" flag and 
the "parent" flag. The synch flag is used at power up to 
properly establish the credit cycle operation described above. 
At power up, the MOM sends synch flags to the QM about every 
10 milliseconds. When the QM has powered up, the QM looks for 
the synch flag, and when found the QM sends a synch 
acknowledge to the MOM. The MOM then will send up any credits 
as described above with the assurance that the QM is ready to 
accept the credits. 

The parent flag is necessary since there can be a 
multiple of physical communication paths multiplexed into one 
channel of a MOM chip. When there is only one communication 
circuit connected to a MOM channel, as when the MOM is 
connected to an Ethernet, the credit system works as described 
above, but with many separate paths into one MOM channel, a 
method of maintaining credits for each of the paths connected 
to the one MOM channel was designed. One important aspect of 
this credit system is that it was necessary to ensure that 
none the several communications paths connected to the one MOM 
channel could be blocked or locked out by another of the 
communication paths. In this embodiment, FIG. 34 shows two 
FIFO channels in a MOM chip. FIFO 800 operates with a single 
communications path. In this case, the MOM FIFO 800 is termed 
a leaf to indicate its operation with a single communications 
circuit. But FIFO 802 is associated with a FIFO channel that 
is connected to another chip, for example, a DAD chip 804 in 
this preferred embodiment, where the DAD is further connected 
to eight other communication circuits 804. In this case the 
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FIFO 802 is termed a "parent" and the eight communications 
circuits connected to the DAD are the leaves . In this 
circumstance the QM maintains a credit for the individual 
leaves attached to the parent FIFO in the MOM. In this way 
5 the QM knows when the transmit FIFOs are filled and can accept 
no further cells. The QM can subsequently transfer cells to 
the other leaf by simply polling the credits in the parent and 
the leaves and transmit cells accordingly. In this manner one 
leaf cannot prevent the servicing of the other leaves. 

10 Referring to FIG. 38, in the Schedule Table 866 in the 

QM, there is an indication 871 whether there is a parent 
associated with that particular circuit. The MOM, acting as a 
parent, sends up credits for the parent FIFO and for each of 
the leaves associated with that parent. 

15 The Parent Credit Table 875 is a 64-entry on-chip table 

in the QM. Each entry contains a credit count for what is 
treated as a u parent circuit." When a circuit is bound to a 
parent circuit, it can only transmit cells onto the MAC bus if 
it has credits available in both its Transmit Context Table 

20 credit field and in its parents credit field in the Parent 
Credit Table. 

When a cell is transmitted for a circuit with a parent, 
both the Transmit Context Table credits and the associated 
parent credits are decremented. Parent credit update cells 
25 from the parent channels are sent back to the QM which causes 
the parent credits to be incremented. 

The Schedule Table is used to bind a circuit to a given 
parent circuit. The Use Parent Circuit Bit (P) 871 and the 
Parent Circuit ID field 872 are used for this purpose. If the 
30 schedule table entry has the P bit set, this means that this 
circuit has a parent and should use the Parent Circuit ID 872 
to index the Parent Credit Table 875. 

9 . Ultra-High Speed Access on RAMBUS® 
RAMBUS® DRAMs 35 and 36 are off-the-shelf items. In the 
35 present invention they are used in a unique manner that 
maximizes the reading and writing bandwidth of the RAMBUS® for 
this data communication application. 
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The invention provides an interface 3 08 to the RAMBUS® 
which utilizes the dual bank organization of a RAMBUS® to 
increase the useful bandwidth of the RAMBUS® memory. Dual 
FIFO stacks are used with a controller to alternately address 
the separate DRAM banks within the RAMBUS®. The FIFOs 
increase the latency and increase the hardware overhead of the 
RAMBUS® controlling electronics, but attempts to guarantee 
that the sequential data written or read comes from the 
alternate banks. In this manner, one bank is precharging 
while the other is being accessed, and then the other bank is 
precharging while the first bank is accessed. 

Referring to FIG. 40, a RAMBUS® 900, is shown in block 
form showing the phase-locked loop, PLL, and the two dynamic 
RAM banks DRAM 1 and 2 (36, 37 respectively) . The multiplexed 
data/address bus into and out of the RAMBUS® is essentially an 
eight-bit wide serial port with an accompanying clock. 

The organization of data buffers in DRAMs 35 and 36 is 
such that all even data buffers (of 128 bytes) are on one bank 
and all odd data buffers are on the other. The arbiter 902 
determines the order in which various requests for data are 
loaded onto FIFO stacks 904 and 906. The buffer addresses in 
the requests are either even or odd, and the requests with 
even buffers are loaded into FIFO 904 and the odd buffers into 
FIFO 906. 

In the condition that the FIFOs are empty, the requests 
are loaded into the even or odd FIFO and the inter leaver 908 
transfers the request to the controller 910. However, as the 
requests become numerous, the requests in the FIFOs back up. 
When the requests have backed up into both FIFOs, the 
interleaver 908 takes the requests alternately from one FIFO 
and then the other { "ping-ponging" ) . Since these buffer 
addresses are alternately even and then odd, the controller 
accesses the two different banks in the RAMBUS® in an 

alternate or interleaved manner. In this operation, the first 
bank is being accessed while the second bank is being 
precharged, and, on the next access, the second bank will be 
accessed while the first bank is being precharged. 
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This alternative accessing substantially provides the 
fastest accessing for either writing or reading of the RAMBUS® 
and maximizes the throughput of the RAMBUS® memory as long as 
there are requests in both FIFO stacks, which is likely in 
5 high traffic situations. In contrast, requests presented on a 
purely FIFO basis likely will have a fractional number with 
back-to-back even or back-to-back odd requests causing a 
fractional number of time-outs to allow precharging. 

Any latency relative to a particular request may in any 
1 0 case have occurred under normal access methods . The method 
here assures maximum usage of RAMBUS® resources under high 
traffic conditions. 

10 . Background Engine/Initialization 

An important part of the invention is the use of the BE, 
15 interfaced on a MOM port during operation to perform 
monitoring and other higher-layer decision making. This 
allows for the BlazeWatch™ and Learn-and-Lock security systems 
for access to configuration and control functions, among other 
applications . 

20 With reference to FIG. 1, a Boot FLASH ROM 51 is provided 

that is accessible to BE 50 for initialization and start up of 
the system. The boot ROM instructions will run when there is 
a power up or a complete system reset. The boot will test and 
verify that the section of the BE DRAM 53 is operational and 

25 reliable. This section is where the ISB code and the BlazeNet 
Runtime Kernel (BeRT) will reside. The first IF (hex) or 32 
(decimal) addresses of ROM 51 hold the initial interrupt 
vectors. Addresses 20-7F hold ROM information; 80-FF hold 
console support interface Routines, 100-4FF hold a MOM 

30 attribute table; 500-1FFFB hold the boot image; and 1FFFC- 
1FFFF hold the boot image checksum of a cyclical redundancy 
check (CRC) . In this embodiment, the remaining BE DRAM 53 
will be tested in parallel with running the BeRT 
initialization process. 

35 The boot also tests the interrupt structure and operation 

to insure that the BARK (the background engine kernel) can 
receive interrupts, for example, from timers. Next the boot 
will initialize the I2C bus 62 and assign addresses to the 
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chips attached to the I2C bus. The boot then determines the 
ID of chips on the bus, including revision level. The boot 
then looks up the ID of the chips found, and an initializer is 
found in the boot directory which is downloaded and executed. 
5 The main system image is in the Nonvolatile Storage 52 in 

a compact flash card containing, for example 10 Mbytes of 
system software. Basic information is transferred on the I2C 
bus to the RE 40 and MOMs 10 and 20. The complete image is 
subsequently transferred on the DMA channel 64. 

10 The above discussion describes the preferred embodiment 

of the invention (s) at the time of filing. It should be clear 
that equivalent components and functions may be substituted 
without departing from the substance of the invent ion(s) . 
Various mixes of hardware and software implementation are 

15 possible while retaining the benefits of the invention ( s) . 
Because the invention is intended to be highly flexible and 
scalable, it is the cooperation of the modules here disclosed 
that is important, rather than the number of modules and 
ports . 
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CLAIMS 

What is claimed is: 

1. A process for flexibly connecting between a receive 
physical path and a transmit physical path the flow of data 
packets, said process comprising: 

(a) receiving data packets on said receive physical path; 

(b) dividing into cells said data packets as received; 

(c) storing said cells in individual data buffers; 

(d) linking logically the location of each buffer 
containing a cell with the location of the buffer 
containing any immediately subsequent cell divided from 
the same data packet; 

(e) scheduling said packets for transmission on said 
transmit physical path; and 

(f) transmitting said cells according to said linking 
among cells so linked. 

2 . The process of Claim 1 wherein said logical linking 
is performed by setting pointers to said buffer locations 
containing said cells and setting linking pointers to point to 
and link said buffer location pointers. 

3 . The process of Claim 2 further comprising the process 
of maintaining in memory pointers to locations of buffers 
available for storing cells by setting a next free buffer 
pointer to the location of the pointer to a first available 
buffer and setting a pointer from said next free buffer 
pointer to the location of the pointer to a second available 
buffer and repeating the process until all available buffers 
are linked and by resetting said next free buffer pointer to 
said second available buffer pointer when a cell is stored in 
said first available buffer. 

4. The process of Claim 1, wherein said receive physical 
path comprises one or more receive circuits and said transmit 
physical path comprises one or more transmit circuits, further 
comprising the processes of writing tags in said received 
cells identifying their source circuits and maintaining a 
receive circuit table with an entry for each circuit logically 
linked to any buffer containing a cell received on said 
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circuit while the data packet from which said received cell 
was divided has not been fully transmitted. 

5. The process of Claim 1 wherein said transmission of 
said cells divided from a received data packet is commenced 

5 prior to the receipt of the tail of said data packet. 

6. The process of Claim 1 further comprising the 
processes of extracting the first cells from said received 
data packets and placing said first cells in a register for 
pipelined processing with rotating send and receive pointers 

10 to a representation of the register such that when said 

receive pointer comes within a certain predefined distance of 
said transmit pointer, extraction is suspended. 

7 . The process of Claim 1 wherein said storing is 
performed by directing cells alternately into one of two 

15 RAMBUS® dynamic random access memory banks. 

8. The process of Claim 1 further comprising the process 
of maintaining a transmit context table with entries for each 
circuit holding respective counts of transmit credits, wherein 
said transmission is performed over a circuit only if the 

20 transmit context table entry for said circuit contains 
adequate transmit credits. 

9 . The process of Claim 8 for a parent channel with 
multiple leaf circuits wherein separate counts of transmit 
credits are kept for the parent channel and are referenced by 

25 a parent channel identification stored in a schedule table 
polled in round-robin fashion to point to entries in a 
transmit context table corresponding to each of said leaf 
circuits . 

10. The process of Claim 8 for a parent channel with 
30 multiple leaf circuits wherein separate counts of transmit 

credits are kept for the parent channel and are referenced by 
a parent channel identification stored in a transmit context 
table entry pointed to by a stand-by scheduler when a normally 
scheduled queue is left idle. 
35 11. The process of Claim 8 wherein credits are issued 

using a ring counter around which a head pointer is moved as 
said cells are transmitted and a virtual tail pointer follows, 
incremented by a maximum cell size as a gap of that size is 
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opened with said head pointier upon the issuance of said credit 
and decremented upon reception of a cell of less than maximum 
size. 

12. The process of Claim 8 wherein transmit credits are 
5 forwarded in headers of said cells for processing at a later 

stage. 

13. The process of Claim 1 wherein said receiving and 
said transmitting are performed by a media interface 
integrated circuit. 

10 14. The process of Claim 13 wherein said dividing of 

data packets into cells is performed by said media interface 
integrated circuit. 

15. The process of Claim 1 wherein said receiving and 
transmitting are distributed between two or more media 

15 interface integrated circuits each with multiple ports. 

16. The process of Claim 15 wherein said media interface 
integrated circuits share a common resource said process 
further comprising the process of arbitrating among said 
interface integrated circuits by detecting of a logical 

20 difference between a single input signal and a single output 
signal . 

17. The process of Claim 16 further comprising the 
process of connecting the single token output by connecting 
the single token output signal of one device to the signal 

25 token input of the next device, with the token output signal 
of the last device is inverted then sent to the first device 
in the passing chain. 

18. The process of Claim 16 wherein said signals are 
read at their respective changes of state. 

30 19. The process of Claim 1 further comprising the 

process of reformatting data fields in data packets in an 
integrated circuit connected to said media interface 
integrated circuits each with multiple ports. 

20. The process of Claim 1 wherein said scheduling is 

35 performed by logically linking packets with a queue, and when 
said queue is selected, dequeuing a packet at the head of the 
queue and transmitting said packet one cell at a time. 
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21. The process of Claim 20 wherein multiple queues are 
formed for a given circuit, said process further comprising 
the process of selecting between said queues according to a 
scheduling algorithm. 

22. The process of Claim 21 wherein the algorithm is a 

"weighted round robin." 

23. The process of Claim 21 wherein the algorithm is 
one-half static and one-half "weighted round robin." 

24. The process of Claim 20 wherein multiple queues are 
formed further comprising the process of selecting between 
said queues according to round-robin polling of a first table 
of pointers to entries of a second table of pointers each 
associated with a circuit. 

25. The process of Claim 24 wherein more than one entry 
in said first table points to a single entry in said second 
table. 

26. The process of Claim 24 wherein said round-robin 
polling is performed over time slots during which selected 
queues may transmit and further comprising the process of 
selecting a stand-by queue for transmission if transmission is 
not performed from said first selected queue for one of said 
time slots. 

27. The process of Claim 26 wherein idle circuits are 
taken out of the stand-by scheduler. 

28. The process of Claim 1 further comprising the 
process of maintaining a table of pointers to said data 
buffers wherein each said pointer is associated with a linking 
pointer and said received cell logical linking is performed by 
setting the linking pointer associated with the pointer to 
said data buffer (a) to point to the pointer to said data 
buffer for said subsequent cell, if any, or else (b) to point 
to the pointer to the data buffer containing the first cell of 
said same data packet to form a ring of links pointing to the 
cell or cells of said same data packet. 

29. The process of Claim 28 further comprising the 
process of maintaining a link list of available data buffers 
by a head pointer pointing to a first of said pointers in said 
table that points to a data buffer available for writing data 
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wherein the linking pointer associated with said first 
available buffer pointer points to a second of said pointers 
in said table that points to another data buffer available for 
writing data and wherein the next received cell is written 
5 into the data buffer pointed to by said pointer pointed to by 
said head pointer and said head pointer reset to point to said 
second available buffer pointer. 

30. The process of Claim 29 further comprising the 
process of returning data buffers to said link list of 

10 available buffers by setting the link pointer associated with 
the last of said link list of available buffers to point to 
one of said pointers in a ring of links associated with a 
transmitted data packet and breaking said ring by resetting 
the linking pointer of one of said pointers in said ring to a 

15 value other than a pointer in said ring. 

31. The process of Claim 30 further comprising the steps 
of maintaining and checking a variable in memory indicating 
whether said process of returning data buffers is to be 
performed relative to a particular ring of links. 

20 32. An apparatus for flexibly connecting between a 

receive physical path and a transmit physical path the flow of 
data packets, said apparatus comprising: 

(a) a receiver; 

(b) a packet to cell parser; 
25 (c) data buffers; 

(d) pointers to data buffers; 

(e) pointers to buffer pointers; 

(f) means for setting pointers to link cells from 
the same packet; 

30 (g) a scheduler; 

(h) means for reassembling cells from the same 
packet; and 

(i) a transmitter. 

33. The apparatus of Claim 32 further comprising 
35 circuitry to write a tag on one of said received cells 

identifying their source circuits and maintaining a receive 
circuit table with an entry for each circuit logically linked 
to any buffer containing a cell received on said circuit while 
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the data packet from which said received circuit was divided 
has not been fully received. 

34. The apparatus of Claim 32 wherein said transmission 
of said cells divided from a received data packet is commenced 

5 prior to the receipt of the tail of said data packet. 

35. The apparatus of Claim 3 2 further comprising means 
for pipelined treatment of the first cell of each packet. 

36. The apparatus of Claim 32 further comprising a media 
interface integrated circuit. 

10 37. The apparatus of Claim 3 6 wherein said media 

interface integrated circuit divides said cells. 

38. The apparatus of Claim 3 6 further comprising two or 
more media interface integrated circuits each with multiple 
ports . 

15 39. The apparatus of Claim 3 8 further comprising a bus 

connecting said interface integrated circuits using token ring 
arbitration. 

40. Apparatus for controlling the transmitting of 
information cells from a sender to a receiver buffer, and 
20 where said receiver transmits the information to a 

communication interface, where said cells are of different 
lengths up to a known maximum, and said receiver of said 
information has limited buffer size, comprising: 

a head pointer that traverses the buffer addresses as the 
25 information is emptied from the buffer and transmitted; 

a tail pointer that traverses the buffer addresses as the 
information is received by the buffer; 

a virtual tail pointer that traverses the empty buffer 
addresses in increments of maximum cell length; 
30 means for determining when the virtual pointer has 

traversed a maximum cell size of empty buffer addresses; 

responsive to the virtual tail pointer traversing a 
maximum empty cell size, means for signaling said sender that 
a cell may be sent to the receiver; 
35 means for determining if the cell received was short of 

the maximum length cell; and 

means for decrementing said virtual tail pointer with the 
shortfall . 
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41. The apparatus as defined in Claim 40 further 
comprising, a start of packet pointer, means for determining 
that a transmitting error occurred, wherein said receiver re- 
transmits the packet by loading the head pointer with the 
start of packet pointer. 

42. The apparatus as defined in Claim 40, wherein the 
means for determining that an error has occurred comprises 
means for determining that a sufficient length of time has 
elapsed or number of bytes has been transmitted to determine 
that no error has occurred. 

43. A RAMBUS® memory controller, said RAMBUS® for 

retrievably storing words, and wherein said RAMBUS® is 

organized into at least two memory banks, comprising: 

means for selecting words from a contiguous streams of 

words to be written into or read from said memory; 

means for accessing alternately a location in one bank of 

said memory followed by a location in another bank of said 

memory, 

means for breaking said stream of words into groups, 
whereby said groups are stored in or read from the at least 
two banks in an interleaved fashion between the at least two 
banks ; and 

means for precharging one bank while the other bank is 
being accessed, in an alternating fashion corresponding to the 
interleaving fashion. 

44. The apparatus as defined in claim 43 further 
comprising: 

at least two FIFO stacks, each FIFO stack corresponding 
to a memory bank, 

an interleave that accesses alternately from one FIFO and 
then the other FIFO, such that consecutive groups of words are 
written into said two banks in an interleaved fashion. 

45. An apparatus for flexibly connecting between a 
receive physical path and a transmit physical path the flow of 
data packets, said apparatus comprising: 

(a) a packet to cell parser; 
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(b) data buffers at defined memory locations adapted 
to receive cell information from said parser; 



(c) pointers at defined memory locations to said 
memory locations of said data buffers; 



5 



(d) resettable pointers at memory locations each 
associated with each said data buffer pointer; and 



10 



15 



(e) a controller adapted to set a resettable pointer 
associated with data buffer pointer to stored cell 
information received from said parser (a) to point 
to said data buffer pointer for a subsequent cell of 
the same data packet, if any, or else (b) to point 
to the pointer to the data buffer containing the 
first cell of said same data packet to form a ring 
of links pointing to the cell or cells of said same 
data packet. 



46. The apparatus of Claim 45 further comprising a 
scheduler comprising a table of pointers to rings of links 
pointing to stored cell information for received data packets 
and a table of circuits on which said received data packets 

20 are to be transmitted one cell at a time according to said 
links . 

47. The apparatus of Claim 46 wherein said scheduler 
further comprises a table of pointers to entries on said table 
of circuits. 

25 48. The apparatus of Claim 46 wherein said scheduler 

further comprises memory entries providing the number of times 
each ring of links is to be cycled for transmission. 
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